package com.zjdiepu.www.ibiz.zx;

import java.util.List;
import java.util.Set;

import com.zjdiepu.www.base.enums.type.OperateType;
import com.zjdiepu.www.model.base.ext.ClientTypeExt;
import com.zjdiepu.www.model.base.vo.BusinessTotalVo;
import com.zjdiepu.www.model.zx.dto.ZxQueryCreditApplySub;
import com.zjdiepu.www.model.zx.ext.ZxQueryCreditApplySubExt;

/**
 * zx_征信查询申请子表-存储配偶及担保人信息Service层操作<br/>
 * @author zhangpp<br/>
 * @time 2017年05月11日 16时15分<br/>
 * @since 1.0<br/>
 */
public interface IZxQueryCreditApplySubService {
	/**
	 * 新增,更新和保存
	 * 
	 * @param ZxQueryCreditApplySub 
	 * @param OperateType 操作类型 {@link OperateType}
	 */
	void saveUpdateAndDelete(ZxQueryCreditApplySub zxQueryCreditApplySub,OperateType operType);
	
	/**
	 * 条件查询
	 * @date 2017年05月11日 16时15分
	 * @param zxQueryCreditApplySubExt
	 * @return
	 */
	List<ZxQueryCreditApplySub> selectByExt(ZxQueryCreditApplySubExt zxQueryCreditApplySubExt);
	
	/**
	 * 条件统计
	 * @date 2017年05月11日 16时15分
	 * @param zxQueryCreditApplySubExt
	 * @return
	 */
	int countByExt(ZxQueryCreditApplySubExt zxQueryCreditApplySubExt);
	
	/**
	 * 主键查询
	 * @date 2017年05月11日 16时15分
	 * @param id
	 * @return
	 */
	ZxQueryCreditApplySub selectById(String id);
	
	/**
	 * 根据主键清除空字段，设置值为null
	 * @date 2017年05月11日 16时15分
	 * @param fieldNames 字段名
	 * @param id 主键
	 */
	void clearEmpty(Set<String> fieldNames, String id);
	/**
	 * 精确统计(=)
	 * @author zhangpp
	 * @time 2017年05月11日 16时15分
	 * @since 1.0
	 * @update
	 * @param sysPower
	 * @return
	 */
	int countRefined(ZxQueryCreditApplySub zxQueryCreditApplySub);
	/**
	 * 精确查询(=)
	 * @author zhangpp
	 * @time 2017年05月11日 16时15分
	 * @since 1.0
	 * @update
	 * @param zxQueryCreditApplySub
	 * @return
	 */
	ZxQueryCreditApplySub selectRefined(ZxQueryCreditApplySub zxQueryCreditApplySub);
	/**
	 * @author zhangpp <br/>
	 * @Title repeat  <br/>
	 * @Description 判断是否重复 <br/>
	 * @param zxQueryCreditApplySub
	 * @return
	 * @version V1.0  <br/>
	 */
	boolean repeat(ZxQueryCreditApplySub zxQueryCreditApplySub);
	
	/**
	 * @author zhangpp <br/>
	 * @Title delectRefined  <br/>
	 * @Description 精确删除(=) <br/>
	 * @param zxQueryCreditApplySub
	 * @return
	 * @version V1.0  <br/>
	 */
	int deletedRefined(ZxQueryCreditApplySub zxQueryCreditApplySub);
	
	/**
	 * @author xiongxiaotun <br/>
	 * @Title: updateBatch  <br/>
	 * @Description:批量删除/禁用/启用  <br/>
	 * @param modifier 修改人
	 * @param modifierName 修改人名称
	 * @param dpStatus 修改后状态
	 * @param ids 待修改数据ID
	 * @return
	 * @version V1.0  <br/>
	 */
	int updateBatch(String modifier, String modifierName, Integer dpStatus, List<String> ids);
	
	/**
	 * @author zhangpp <br/>
	 * @Title: insertBatch  <br/>
	 * @Description: 批量添加 <br/>
	 * @param zxQueryCreditApplySubs
	 * @return
	 * @version V1.0  <br/>
	 */
	int insertBatch(List<ZxQueryCreditApplySub> zxQueryCreditApplySubs);

	int countZXNum(ClientTypeExt clientTypeExt);

	List<BusinessTotalVo> selectZXNum(ClientTypeExt clientTypeExt);

	int countAllZXNum(ClientTypeExt clientTypeExt);
	
}
